<!--
 * @description 小组审核列表
 * @author dumeng
 * @date 2021/9/17
 -->
<template>
  <section class="group-check-list">
    <el-collapse-transition>
      <section v-show="searchshow" class="main-search merge">
        <span class="svg-container">
          <svg-icon icon-class="search" />
        </span>
        <el-input
          v-model.trim="listQuery.commitName"
          placeholder="输入提交人搜索"
          class="search-input"
          @keyup.enter.native="handleFilter"
        />
        <section class="search-btn">
          <el-button class="filter-item" type="primary" @click="handleFilter">搜索</el-button>
          <el-button type="primary" @click="handleReset">重置</el-button>
          <span class="search-more" @click="searchshow = !searchshow">
            更多筛选条件
            <i class="el-icon-arrow-down" />
          </span>
        </section>
      </section>
    </el-collapse-transition>
    <el-collapse-transition>
      <section v-show="!searchshow" class="main-search separate">
        <section class="search-inner">
          <el-row>
            <el-col :span="12">
              <section class="search-inner-item">
                <div class="item-label">提交人</div>
                <el-input
                  v-model.trim="search.commitName"
                  style="width: 90%;"
                  class="filter-item"
                  placeholder="请输入提交人搜索"
                />
              </section>
            </el-col>
            <el-col v-if="activeTab!=='AUDITRESULT01'" :span="12">
              <section class="search-inner-item">
                <div class="item-label">审核人</div>
                <el-input
                  v-model.trim="search.auditUserName"
                  style="width: 90%;"
                  class="filter-item"
                  placeholder="请输入审核人搜索"
                />
              </section>
            </el-col>
            <el-col :span="12">
              <section class="search-inner-item">
                <div class="item-label">小组名称</div>
                <el-input
                  v-model.trim="search.groupName"
                  style="width: 90%;"
                  class="filter-item"
                  placeholder="请输入小组名称搜索"
                />
              </section>
            </el-col>
            <!--            <el-col :span="12">-->
            <!--              <section class="search-inner-item">-->
            <!--                <div class="item-label">审核类型</div>-->
            <!--                <el-select v-model="search.commitType" placeholder="请选择审核类型" style="width: 80%;">-->
            <!--                  <el-option-->
            <!--                    v-for="(item, index) in dict.XZSHLX"-->
            <!--                    :key="index"-->
            <!--                    :label="item.dictName"-->
            <!--                    :value="item.dictValue"-->
            <!--                  />-->
            <!--                </el-select>-->
            <!--              </section>-->
            <!--            </el-col>-->

          </el-row>
        </section>
        <section class="search-btn">
          <el-button type="primary" @click="handleFilter">搜索</el-button>
          <el-button type="primary" @click="handleReset">重置</el-button>
          <span class="search-more" @click="searchshow = !searchshow">
            精简筛选条件
            <i class="el-icon-arrow-up" />
          </span>
        </section>
      </section>
    </el-collapse-transition>

    <section class="main-buttons">
      <section class="main-buttons-title">
        <span>小组审核</span>
      </section>
    </section>
    <div class="classify-tab">
      <el-tabs v-model="activeTab" @tab-click="handleTabClick">
        <el-tab-pane v-for="item in checkList" :key="item.id" :label="item.name" :name="item.id" />
      </el-tabs>
    </div>
    <section class="main-table">
      <v-table
        :list="list"
        :tag="'groupCheckList' + tab"
        :list-loading="listLoading"
        :filter-column="filtercolumn"
        :selection="false"
      >
        <el-table-column label="操作" fixed="right" align="center" min-width="100" class-name="small-padding fixed-width">
          <template slot-scope="scope">
            <el-button v-if="activeTab === 'AUDITRESULT01'" type="text" size="mini" @click="handleCheck(scope.row)">审核</el-button>
            <el-button v-else type="text" size="mini" @click="handleView(scope.row)">查看</el-button>
          </template>
        </el-table-column>
      </v-table>
      <pagination
        v-show="total>0"
        :total="total"
        :page.sync="listQuery.page"
        :limit.sync="listQuery.limit"
        @pagination="getList"
      />

    </section>
  </section>
</template>
<script>
import Pagination from '@/components/Pagination'
import VTable from '@/components/Table'
import { queryPage, getDictByCode } from '../api/check'
import permission from '@/directive/permission'

export default {
  name: 'GroupCheckList',
  components: { Pagination, VTable },
  directives: { permission },
  data() {
    return {
      searchshow: true,
      listQuery: {
        page: 1,
        limit: 10,
        commitName: ''
      },
      search: {
        commitName: '',
        auditUserName: '',
        commitType: ''

      },
      activeTab: 'AUDITRESULT01',
      checkList: [
        {
          name: '待审核',
          id: 'AUDITRESULT01'
        }, {
          name: '已通过',
          id: 'AUDITRESULT02'
        },
        {
          name: '未通过',
          id: 'AUDITRESULT03'
        }
      ],
      list: [],
      total: 0,
      listLoading: false,
      dict: {
        XZSHLX: []
      },
      tab: '1'
    }
  },
  watch: {
    activeTab(val) {
      if (val === 'AUDITRESULT01') {
        this.tab = '1'
      } else {
        this.tab = '2'
      }
    }
  },
  created() {
    this.activeTab = this.$route.query.tab || 'AUDITRESULT01'
    for (const i in this.dict) {
      this.getDict(i)
    }
    this.getList()
  },
  methods: {
    getDict(code) {
      return new Promise((resolve, reject) => {
        getDictByCode(code).then(response => {
          this.dict[code] = response.data.data[0].list
          resolve()
        }).catch(error => {
          reject(error)
        })
      })
    },
    handleBack() {
      this.$router.back()
    },
    /**
     * 选项卡切换
     */
    handleTabClick() {
      this.listQuery.page = 1
      this.getList()
    },
    filtercolumn(scope, item) {
      return scope.row[item]
    },

    handleReset() {
      this.listQuery.page = 1
      this.listQuery.userRealName = ''
      for (const i in this.search) {
        if (this.search['' + i + ''] instanceof Array) {
          this.search['' + i + ''] = []
        } else {
          this.search['' + i + ''] = ''
        }
      }
      this.getList()
    },
    handleFilter() {
      this.listQuery.page = 1
      this.getList()
    },

    handleCheck(row) {
      this.$router.push({
        path: this.$filterPath('groupCheck'),
        query: { i: row.id, type: 'check', tab: this.activeTab }
      })
    },

    handleView(row) {
      this.$router.push({
        path: this.$filterPath('groupCheck'),
        query: { i: row.id, type: 'view', tab: this.activeTab }
      })
    },

    getList(obj) {
      this.listLoading = true
      const query = {
        page: obj ? obj.page : this.listQuery.page,
        pageSize: obj ? obj.limit : this.listQuery.limit,
        auditStatus: this.activeTab,
        commitType: 'TYPE_XZCL,TYPE_XZXG,TYPE_XZYJ,TYPE_XZJS'
      }
      if (this.searchshow) {
        query['commitName'] = this.listQuery.commitName
      } else {
        query['commitName'] = this.search.commitName
        query['auditUserName'] = this.search.auditUserName
        query['groupName'] = this.search.groupName
      }

      return new Promise((resolve, reject) => {
        queryPage(query).then(response => {
          this.list = response.data.data.rows
          this.total = response.data.data.total
          this.listLoading = false
        }).catch(error => {
          reject(error)
          this.listLoading = false
        })
      })
    }
  }
}
</script>
<style lang="scss">

.group-check-list {
  padding: 10px;

  .main-search {
    background-color: #fff;
    padding: 0 10px;

    .svg-container {
      padding: 0 5px 0 10px;
      color: #bfced6;
      vertical-align: middle;
      display: inline-block;
    }

    .search-input {
      width: 60%;
      position: relative;

      &:after {
        content: '';
        position: absolute;
        left: -25px;
        right: 0;
        bottom: 8px;
        height: 1px;
        background: rgba(226, 227, 232, 1);
      }

      input {
        outline: none;
        background: transparent;
        border: none;
        outline: medium;
        padding: 0;

        &:focus {
          outline: none;
          background-color: transparent;
        }
      }
    }

    .search-btn {
      display: inline-block;
      float: right;

      .el-button.is-round {
        padding: 10px 30px;
        margin-right: 34px;
      }

      .search-more {
        font-size: 14px;
        font-weight: 500;
        @include font-color($mainColor);
        cursor: pointer;
        margin-left: 10px;
      }
    }

    &.merge {
      height: 50px;
      line-height: 50px;
    }

    &.separate {
      .search-inner {
        padding-top: 10px;

        .search-inner-item {
          .item-label {
            height: 30px;
            line-height: 30px;
            font-size: 14px;
            color: #a6a6a6;
            font-weight: 400;
          }

          .el-input {
            position: relative;

            &.el-date-editor input {
              padding-left: 30px;
            }

            .el-input__inner {
              border: none;
              padding: 0;
            }

            &:after {
              content: '';
              height: 1px;
              background-color: #e2e3e8;
              position: absolute;
              left: 0;
              right: 0;
              bottom: 0;
            }
          }
        }
      }

      .search-btn {
        text-align: center;
        display: block;
        float: none;
        height: 56px;
        line-height: 56px;
      }
    }
  }

  .classify-tab {
    width: 100%;
    margin-bottom: 10px;
    padding: 0 10px;
    background-color: #fff;
    display: flex;
    border-radius: 4px;

    .el-tabs__nav-wrap::after {
      display: none;
    }

    .el-tabs__header {
      margin: 0;
    }
  }

  .main-buttons {
    display: flex;
    line-height: 36px;
    margin-top: 10px;

    .main-buttons-title {
      flex: 1;
      height: 36px;
      line-height: 36px;
      font-size: 16px;
      font-weight: bold;
      color: rgba(51, 51, 51, 1);
    }
  }
}
</style>
